<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "https://www.w3.org/TR/html4/loose.dtd">
<html lang="zh-CN"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"><meta http-equiv="Content-Language" content="zh-CN"><link href="stylesheet.css" media="all" rel="stylesheet" type="text/css">
<title>自定义的选项</title>
<script> var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?d286c55b63a3c54a1e43d10d4c203e75"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })(); </script>
</head><body class="SECT1">
<div>
<table summary="Header navigation table" width="100%" border="0" cellpadding="0" cellspacing="0">
<tr><th colspan="5" align="center" valign="bottom">PostgreSQL 8.2.3 中文文档</th></tr>
<tr><td width="10%" align="left" valign="top"><a href="runtime-config-preset.html" accesskey="P">后退</a></td><td width="10%" align="left" valign="top"><a href="runtime-config.html">快退</a></td><td width="60%" align="center" valign="bottom">章17. 服务器配置</td><td width="10%" align="right" valign="top"><a href="runtime-config.html">快进</a></td><td width="10%" align="right" valign="top"><a href="runtime-config-developer.html" accesskey="N">前进</a></td></tr>
</table>
<hr align="LEFT" width="100%"></div>
<div class="SECT1"><h1 class="SECT1"><a name="RUNTIME-CONFIG-CUSTOM">17.14. 自定义的选项</a></h1>
<p>这个特性用来允许那些由附加模块添加(比如过程语言)的选项，通常 PostgreSQL 并不知道它们。这样，附加的模块就可以用标准的方式配置。</p>
<div class="VARIABLELIST">
<dl>
<dt><a name="GUC-CUSTOM-VARIABLE-CLASSES"></a><tt class="VARNAME">custom_variable_classes</tt> (<tt class="TYPE">string</tt>)</dt>
<dd><p>这个变量以逗号分隔的列表声明一个或多个用于自定义变量的类名称。自定义变量通常是 PostgreSQL 并不知道的变量，但是被一些附加的模块使用。这样的变量名必须由一个类别名、一个点、一个变量名组成。<tt class="VARNAME">custom_variable_classes</tt> 声明在一次安装里的所有类别名。这个选项只能在服务器启动的时候或者在 <tt class="FILENAME">postgresql.conf</tt> 文件里设置。</p></dd>
</dl>
</div>
<p>在 <tt class="FILENAME">postgresql.conf</tt> 里设置自定义变量的困难在于这个文件必须在附加模块被装载之前读取，因此自定义变量通常会被认为是未知而拒绝。在设置了 <tt class="VARNAME">custom_variable_classes</tt> 之后，服务器将接受每个声明的类别里的任意变量。这些变量将被当作占位符，并且在定义它们的模块装载之前没有任何用处。在一个特定类别的模块加载后，它将为这个类别名增加合适的变量定义，根据它们的定义把那些占位符数值进行转换，并且为该类别剩下的任何占位符发出警告(这些很有可能是拼写错的配置变量)。</p>
<p>下面是一个在使用自定义变量时 <tt class="FILENAME">postgresql.conf</tt> 可能包含的东西的例子。</p>
<pre class="PROGRAMLISTING">custom_variable_classes = 'plr,plperl'
plr.path = '/usr/lib/R'
plperl.use_strict = true
plruby.use_strict = true        # 生成一个错误：未知的类名(unknown class name)</pre>
</div>
<div>
<hr align="LEFT" width="100%">
<table summary="Footer navigation table" width="100%" border="0" cellpadding="0" cellspacing="0">
<tr><td width="33%" align="left" valign="top"><a href="runtime-config-preset.html" accesskey="P">后退</a></td><td width="34%" align="center" valign="top"><a href="index.html" accesskey="H">首页</a></td><td width="33%" align="right" valign="top"><a href="runtime-config-developer.html" accesskey="N">前进</a></td></tr>
<tr><td width="33%" align="left" valign="top">预置选项</td><td width="34%" align="center" valign="top"><a href="runtime-config.html" accesskey="U">上一级</a></td><td width="33%" align="right" valign="top">开发人员选项</td></tr>
</table>
</div>
</body></html>